package com.charity.mapper;

import com.baomidou.mybatisplus.core.mapper.BaseMapper;
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
import com.charity.domain.News;
import org.apache.ibatis.annotations.*;

import java.util.List;

@Mapper
public interface NewsMapper extends BaseMapper<News> {
    /**
     * 查询新闻列表
     * @param category 新闻分类
     * @param page 分页参数
     * @return 新闻列表
     */
    @Select("SELECT * FROM news WHERE category = #{category}")
    Page<News> selectList(@Param("category") String category, Page<News> page);

    /**
     * 更新新闻状态
     * @param newsId 新闻ID
     * @param status 状态
     * @return 影响行数
     */
    @Update("UPDATE news SET status = #{status} WHERE id = #{newsId}")
    int updateStatus(@Param("newsId") Long newsId, @Param("status") Integer status);

    /**
     * 获取热门新闻
     * @param limit 限制数量
     * @return 热门新闻列表
     */
    @Select("SELECT * FROM news ORDER BY views DESC LIMIT #{limit}")
    List<News> selectTopByViews(@Param("limit") int limit);

    /**
     * 增加新闻浏览量
     * @param newsId 新闻ID
     * @return 影响行数
     */
    @Update("UPDATE news SET views = views + 1 WHERE id = #{newsId}")
    int incrementViews(Long newsId);
}